# **ADNS-9500**

# LaserStream™ Gaming Sensor



# **Data Sheet**



## **Description**

The ADNS-9500 LaserStream gaming sensor comprises of sensor and VCSEL in a single chip-on-board (COB) package. ADNS-9500 provides enhanced features like programmable frame rate, programmable resolution, configurable sleep and wake up time to suit various PC gamers' preferences.

The advanced class of VCSEL was engineered by Avago Technologies to provide a laser diode with a single longitudinal and a single transverse mode.

This LaserStream gaming sensor is in 16-pin integrated chip-on-board (COB) package. It is designed to be used with ADNS-6190-002 small form factor (SFF) gaming laser lens to achieve the optimum performance featured in this document. These parts provide a complete and compact navigation system without moving part and laser calibration process is NOT required in the complete mouse form, thus facilitating high volume assembly.

## **Theory of Operation**

The sensor is based on LaserStream technology, which measures changes in position by optically acquiring sequential surface images (frames) and mathematically determining the direction and magnitude of movement. It contains an Image Acquisition System (IAS), a Digital Signal Processor (DSP), and a four wire serial port. The IAS acquires microscopic surface images via the lens and illumination system. These images are processed by the DSP to determine the direction and distance of motion. The DSP calculates the  $\Delta x$  and  $\Delta y$  relative displacement values. An external microcontroller reads the  $\Delta x$  and  $\Delta y$  information from the sensor serial port. The microcontroller then translates the data into PS2, USB, or RF signals before sending them to the host PC or game console.

#### **Features**

- Small form factor chip-on-board package
- Dual power supply selections, 3V or 5V
- VDDIO range: 1.65 3.3V
- 16-bits motion data registers
- High speed motion detection at 150ips and acceleration up to 30g
- Advanced technology 832-865nm wavelength VCSEL
- Single mode lasing
- No laser power calibration needed
- Compliance to IEC/EN 60825-1 Eye Safety
  - Class 1 laser power output level
  - On-chip laser fault detect circuitry
- Self-adjusting frame rate for optimum performance
- Motion detect pin output
- Internal oscillator no external clock input needed
- Enhanced Programmability
  - Frame rate up to 11,750 fps
  - 1 to 5 mm lift detection
  - Resolution up to 5670cpi with ~90cpi step
  - X and Y axes independent resolution setting
  - Register enabled Rest Modes
  - Sleep and wake up times

## **Applications**

- Corded and cordless gaming laser mice
- Optical trackballs
- Motion input devices

**CAUTION:** It is advised that normal static precautions be taken in handling and assembly of this component to prevent damage and/or degradation which may be induced by ESD.

# Pinout of ADNS-9500 Optical Mouse Sensor

| Pin No | Pin Name for 5V mode | Pin Name for 3V mode | Description                                                          |
|--------|----------------------|----------------------|----------------------------------------------------------------------|
| 1      | +VCSEL               | +VCSEL               | Positive Terminal Of VCSEL                                           |
| 2      | LASER_NEN            | LASER_NEN            | LASER Enable (Active Low Output)                                     |
| 3      | NCS                  | NCS                  | Chip Select (Active Low Input)                                       |
| 4      | MISO                 | MISO                 | Serial Data Output (Master In/Slave Out)                             |
| 5      | SCLK                 | SCLK                 | Serial Clock Input                                                   |
| 6      | MOSI                 | MOSI                 | Serial Data Input (Master Out/Slave In)                              |
| 7      | MOTION               | MOTION               | Motion Detect (Active Low Output)                                    |
| 8      | XYLASER              | XYLASER              | Laser Current Output Control                                         |
| 9      | VDD5                 | VDD3                 | 5V input for 5V mode<br>3V Input for 3V mode                         |
| 10     | PWR_OPT (GND)        | PWR_OPT (VDD3)       | Power Option: Connect to GND for 5V Mode Connect to VDD3 for 3V Mode |
| 11     | GND                  | GND                  | Analog Ground                                                        |
| 12     | REFB                 | VDD3                 | 3V Regulator Output for 5V Mode<br>3V Input for 3V Mode              |
| 13     | REFA                 | REFA                 | 1.8V Regulator Output                                                |
| 14     | DGND                 | DGND                 | Digital Ground                                                       |
| 15     | VDDIO                | VDDIO                | IO Voltage Input (1.65 - 3.3V)                                       |
| 16     | -VCSEL               | -VCSEL               | Negative Terminal Of VCSEL                                           |



W = Subcon Code

XXYY = Date Code

Z = Sensor Die Source

V = VCSEL Die Source

Figure 1. Package Pinout



#### Notes:

- 1. Dimensions in millimeter
- 2. Dimension tolerance  $\pm 0.1$ mm unless specified otherwise
- 3. Coplanarity of leads: 0.15mm
- 4. Lead pitch tolerance: ±0.15mm
- 5. Non-cumulative lead pitch tolerance ±0.15mm
- 6. Maximum flash +0.2mm
- 7. Lead width: 0.5mm
- 8. Bracket ( ) indicates reference dimensions

**TOP VIEW** 







**BOTTOM VIEW** 

Figure 2. Package outline drawing

# **Overview of Laser Mouse Sensor Assembly**





Note: Dimensions in millimeter and for reference only

Figure 3. 2D Assembly drawing of ADNS-9500 sensor and ADNS-6190-002 lens coupled with PCB and base plate



Figure 4. Isometric drawing of ADNS-9500 sensor and ADNS-6190-002 lens



Figure 5. Recommended PCB mechanical cutouts and spacing

## **Assembly Recommendation**

- 1. Insert the COB sensor and all other electrical components into the application PCB.
- 2. This sensor package is only qualified for wave-solder process.
- 3. Wave-solder the entire assembly in a no-wash soldering process utilizing a solder fixture. The solder fixture is needed to protect the sensor during the solder process. The fixture should be designed to expose the sensor leads to solder while shielding the optical aperture from direct solder contact.
- 4. Place the lens onto the base plate. Care must be taken to avoid contamination on the optical surfaces.
- Remove the protective kapton tapes from the optical aperture of the sensor and VCSEL respectively. Care must be taken to keep contaminants from entering the aperture.
- 6. Insert the PCB assembly over the lens onto the base plate. The sensor package should self-align to the lens. The optical position reference for the PCB is set by the base plate and lens. The alignment guide post of the lens locks the lens and integrated molded lead-frame DIP sensor together. Note that the PCB motion due to button presses must be minimized to maintain optical alignment.
- 7. Optional: The lens can be permanently locked to the sensor package by melting the lens' guide posts over the sensor with heat staking process.
- 8. Install the mouse top case. There must be a feature in the top case (or other area) to press down onto the sensor to ensure the sensor and lenses are interlocked to the correct vertical height.

# **Application Circuits**

∝≥യമ



Figure 6a. Schematic Diagram for 5V Corded Mouse



Figure 6b. Schematic Diagram for 3V Cordless Mouse



Figure 7. Block diagram of ADNS-9500

## **Regulatory Requirements**

- Passes FCC B and worldwide analogous emission limits when assembled into a mouse with shielded cable and following Avago recommendations.
- Passes IEC-1000-4-3 radiated susceptibility level when assembled into a mouse with shielded cable and following Avago recommendations.
- Passes EN61000-4-4/IEC801-4 EFT tests when assembled into a mouse with shielded cable and following Avago recommendations.
- Passes IEC-61000-4-2 Electrostatic Discharge Immunity Test (ESD) and provides sufficient ESD creepage/ clearance distance to withstand discharge up to 15KV when assembled into a mouse according to usage instructions above.
- Passes IEC/EN 60825-1 Eye Safety Class 1 when operating with the laser output power pre-calibrated by Avago Technologies without external hardware and software control of laser current.

### **Design Considerations for Improving ESD Performance**

For improved electrostatic discharge performance, typical creepage and clearance distance are shown in the table below. Assumption: base plate construction as per the Avago supplied 3D model file when use with ADNS-6190-002 lens. The lens flange can be sealed (i.e. glued) to the base plate. Note that the lens material is polycarbonate and therefore, cyanoacrylate based adhesives or other adhesives that may damage the lens should NOT be used.

| Typical Distance (mm) | ADNS-6190-002 |
|-----------------------|---------------|
| Creepage              | 17.3          |
| Clearance             | 1.8           |

## **Eye Safety**

The ADNS-9500 sensor and the associated components in the schematic of Figure 6 are intended to comply with Class 1 Eye Safety Requirements of IEC 60825-1. Avago Technologies calibrates the sensor's laser output power (LOP) to Class 1 eye safety level and store the registers values that control the LOP prior shipping out, thus no LOP calibration is required in complete mouse system at manufacturer site.

ADNS-9500 sensor is designed to maintain the laser output power using ADNS-6190-002 lens within Class 1 Eye Safety requirements over components manufacturing tolerances under the recommended operating conditions and application circuits of Figure 6 as specified in this document. Under normal operating conditions, the sensor generates the drive current for the VCSEL. Increasing the LOP by other means on hardware and software can result in a violation of the Class 1 eye safety limit of 716µW. For more information, please refer to Eye Safety Application Note.

#### **LASER Drive Mode**

The laser is driven in pulsed mode during normal operation. A calibration mode is provided which drives the laser in continuous (CW) operation for testing purpose.

The default setting of laser is in Forced\_Disable mode, which the laser is turned OFF. The laser have to be turned ON during power up sequence by setting Forced\_Disabled bit (Bit-0) of LASER CTRL0 register to 0.

#### Disabling the LASER

LASER\_NEN is connected to the gate of an external P-channel MOSFET transistor which, when ON connects REFB to the laser. In normal operation, LASER\_NEN is low. In the case of a fault condition, LASER\_NEN goes high to turn the transistor off and disconnect REFB from the laser.

## LASER Output Power (LOP)

The LOP can be measured for testing purpose as per steps below.

- 1. Power up reset the mouse system.
- 2. Enable the laser by setting Forced\_Disabled bit of LASER\_CTRL0 register (address 0x20) to 0.
- 3. Enable the Calibration mode by writing 010b to bits [3,2,1] of LASER\_CTRL0 register (address 0x20) to set the laser to continuous (CW) mode.
- 4. Measure the LOP at the navigation surface plane.

The pre-calibrated LOP value at typical operating supply voltage and temperature of  $25 \pm 5^{\circ}$ C should not exceeding 506µW, otherwise the LOPmax limit in the Absolute Maximum Rating is applicable. The following conditions apply:

- The system is operated within the recommended operating supply voltage and temperature range.
- In 3V mode, the VDD3 value is no greater than 300mV above the pre-calibration voltage of 3.0V. In 5V mode, REFB should be used to drive the PMOSFET connecting to VCSFI
- No allowance for optical power meter accuracy is assumed.

## **Single Fault Detection**

ADNS-9500 sensor is able to detect a short circuit or fault condition at –VCSEL pin, which could lead to excessive laser output power. A leakage path to ground on this node will trigger the fault detection circuit, which will turn off the laser drive current source and set the LASER\_NEN output high. When used in combination with external component as shown in the block diagram below, the system will prevent excessive laser power for a resistive path at XY\_LASER by shutting off the laser. In addition to the ground path fault detection described above, the fault detection circuit is periodically checking for proper operation by internally generating a path to ground with the laser turned off via LASER\_NEN. If the –VCSEL pin is shorted to VDD5, VDD3, REFA or REFB pin, this test will fail and will be reported as a fault.



Figure 8. Single Fault Detection and Eye-safety Feature Block Diagram

# **Absolute Maximum Ratings**

| Parameter                | Symbol             | Minimum | Maximum | Units | Notes                                                                                                                                                          |
|--------------------------|--------------------|---------|---------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Storage Temperature      | Ts                 | -40     | 85      | °C    |                                                                                                                                                                |
| Lead-Free Solder Temp    |                    |         | 260     | °C    | For 7 seconds, 1.8mm below seating plane. Refer to soldering reflow profile in PCB Assembly & Soldering Considerations Application Note AN 5023.               |
| Supply Voltage           | V <sub>DD5</sub>   | -0.5    | 5.5     | V     |                                                                                                                                                                |
|                          | $V_{DD3}$          | -0.5    | 3.4     | V     |                                                                                                                                                                |
|                          | V <sub>DDIO</sub>  | -0.5    | 3.4     | V     |                                                                                                                                                                |
| ESD (Human body model)   |                    |         | 2       | kV    | All Pins                                                                                                                                                       |
| Input Voltage            | V <sub>IN</sub>    | -0.5    | 3.4     | V     | All I/O Pins                                                                                                                                                   |
| Laser Output Power       | LOP <sub>max</sub> |         | 716     | μW    | Class 1 Eye Safety Limit                                                                                                                                       |
| VCSEL DC Forward Current | lF                 |         | 7       | mA    | For maximum duration of 240 hrs Applicable when driving VCSEL externally and internally using sensor's laser registers setting Refer to reliability datasheet. |
| VCSEL Reverse Voltage    | $V_R$              |         | 5       | V     | Ι = 10 μΑ                                                                                                                                                      |

#### Comments:

- 1. Stresses greater than those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are the stress ratings only and functional operation of the device at these or any other condition beyond those indicated for extended period of time may affect device reliability.
- 2. The inherent design of this component causes it to be sensitive to electrostatic discharge. The ESD threshold is listed above. To prevent ESD-induced damage, take adequate ESD precautions when handling this product.

# **Recommended Operating Conditions**

| Parameter                                     | Symbol            | Minimum | Typical | Maximum | Units             | Notes                                                               |
|-----------------------------------------------|-------------------|---------|---------|---------|-------------------|---------------------------------------------------------------------|
| Operating Temperature                         | T <sub>A</sub>    | 0       |         | 40      | °C                |                                                                     |
| Supply voltage                                | $V_{\text{DD5}}$  | 4.0     | 5.0     | 5.25    | Volts             | Including Supply Noise for 5V mode                                  |
|                                               | $V_{DD3}$         | 2.7     | 2.8     | 3.3     | Volts             | Including Supply Noise for 3V mode                                  |
|                                               | $V_{\text{DDIO}}$ | 1.65    |         | 3.3     | Volts             | Including noise.                                                    |
| Power supply rise time                        | $V_{RT5}$         | 1       |         | 100     | ms                | 0 to 5.0V for 5V mode                                               |
|                                               | V <sub>RT3</sub>  | 1       |         | 100     | ms                | 0 to 2.8V for 3V mode                                               |
| Supply noise (Sinusoidal)                     | V <sub>NA</sub>   |         |         | 100     | mV <sub>p-p</sub> | 50kHz - 50MHz                                                       |
| Serial Port Clock Frequency                   | f <sub>SCLK</sub> |         |         | 2       | MHz               | Active drive, 50% duty cycle                                        |
| Distance from lens reference plane to surface | Z                 | 2.18    | 2.40    | 2.62    | mm                | Results in +/- 0.22mm minimum<br>DOF. Refer to Figure 9.            |
| Speed                                         | S                 |         | 150     | 200     | ips               | inch/sec<br>Maximum speed performance on<br>select gaming surfaces. |
| Acceleration                                  | Α                 |         |         | 30      | g                 | In Run mode only                                                    |
| Load Capacitance                              | C <sub>out</sub>  |         |         | 100     | pF                | MOTION, MISO                                                        |
| Frame Rate                                    | FR                |         |         | 11,750  | fps               | Frame per second                                                    |
| VCSEL Peak Wavelength                         | λ                 | 832     |         | 865     | nm                |                                                                     |



Figure 9. Distance from lens reference plane to surface, Z

# **AC Electrical Specifications**

Electrical Characteristics over recommended operating conditions. (Typical values at 25  $^{\circ}$ C, VDD3 = 2.8V, VDDIO = 1.8V)

| Parameter                                     | Symbol                               | Minimum | Typical | Maximum | Units | Notes                                                                                                                                                    |
|-----------------------------------------------|--------------------------------------|---------|---------|---------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Motion delay after reset                      | t <sub>MOT-RST</sub>                 | 30      |         |         | ms    | From SW_RESET register write to<br>valid motion, assuming motion is<br>present                                                                           |
| Shutdown                                      | t <sub>STDWN</sub>                   |         |         | 500     | ms    | From Shutdown mode active to low current                                                                                                                 |
| Wake from shutdown                            | twakeup                              | 30      |         |         | ms    | From Shutdown mode inactive to valid motion. Notes: A RESET must be asserted after a shutdown. Refer to Shutdown section, also note t <sub>MOT-RST</sub> |
| Forced Rest enable                            | t <sub>REST-EN</sub>                 |         |         | 1       | S     | From RESTEN bits set to low current                                                                                                                      |
| Wake from Forced Rest                         | t <sub>REST-DIS</sub>                |         |         | 1       | S     | From RESTEN bits cleared to valid motion                                                                                                                 |
| MISO rise time                                | t <sub>r-MISO</sub>                  |         | 50      | 200     | ns    | C <sub>L</sub> = 100pF                                                                                                                                   |
| MISO fall time                                | t <sub>f-MISO</sub>                  |         | 50      | 200     | ns    | C <sub>L</sub> = 100pF                                                                                                                                   |
| MISO delay after SCLK                         | t <sub>DLY-MISO</sub>                |         |         | 120     | ns    | From SCLK falling edge to MISO data valid, no load conditions                                                                                            |
| MISO hold time                                | t <sub>hold-MISO</sub>               | 200     |         |         | ns    | Data held until next falling SCLK edge                                                                                                                   |
| MOSI hold time                                | t <sub>hold-MOSI</sub>               | 200     |         |         | ns    | Amount of time data is valid after SCLK rising edge                                                                                                      |
| MOSI setup time                               | t <sub>setup-MOSI</sub>              | 120     |         |         | ns    | From data valid to SCLK rising edge                                                                                                                      |
| SPI time between write commands               | t <sub>SWW</sub>                     | 120     |         |         | μs    | From rising SCLK for last bit of the first data byte, to rising SCLK for last bit of the second data byte.                                               |
| SPI time between write and read commands      | t <sub>SWR</sub>                     | 120     |         |         | μs    | From rising SCLK for last bit of the first data byte, to rising SCLK for last bit of the second address byte.                                            |
| SPI time between read and subsequent commands | t <sub>SRW</sub><br>t <sub>SRR</sub> | 20      |         |         | μs    | From rising SCLK for last bit of the first data byte, to falling SCLK for the first bit of the address byte of the next command.                         |
| SPI read address-data delay                   | t <sub>SRAD</sub>                    | 100     |         |         | μs    | From rising SCLK for last bit of the address byte, to falling SCLK for first bit of data being read.                                                     |
| NCS inactive after motion burst               | t <sub>BEXIT</sub>                   | 500     |         |         | ns    | Minimum NCS inactive time after motion burst before next SPI usage                                                                                       |
| NCS to SCLK active                            | t <sub>NCS-SCLK</sub>                | 120     |         |         | ns    | From last NCS falling edge to first<br>SCLK rising edge                                                                                                  |
| SCLK to NCS inactive (for read operation)     | t <sub>SCLK-NCS</sub>                | 120     |         |         | ns    | From last SCLK rising edge to NCS ris-<br>ing edge, for valid MISO data transfer                                                                         |
| SCLK to NCS inactive (for write operation)    | t <sub>SCLK-NCS</sub>                | 20      |         |         | us    | From last SCLK rising edge to NCS ris-<br>ing edge, for valid MOSI data transfer                                                                         |
| NCS to MISO high-Z                            | t <sub>NCS-MISO</sub>                |         |         | 500     | ns    | From NCS rising edge to MISO high-Z state                                                                                                                |
| MOTION rise time                              | t <sub>r-MOTION</sub>                |         | 50      | 200     | ns    | C <sub>L</sub> = 100pF                                                                                                                                   |
| MOTION fall time                              | t <sub>f-MOTION</sub>                |         | 50      | 200     | ns    | C <sub>L</sub> = 100pF                                                                                                                                   |
| Transient Supply Current                      | I <sub>DDT5</sub>                    |         |         | 90      | mA    | Max supply current during a V <sub>DD5</sub> ramps from 0 to 5.0V                                                                                        |
|                                               | I <sub>DDT3</sub>                    |         |         | 65      | mA    | Max supply current during a V <sub>DD3</sub> ramps from 0 to 2.8V                                                                                        |

# **DC Electrical Specifications**

Electrical Characteristics over recommended operating conditions.

For 3V mode, Typical values at 25°C,  $V_{DD} = 2.8 \text{ V}$ ,  $V_{DDIO} = 2.8 \text{ V}$ . For 5V mode, Typical values at 25°C,  $V_{DD} = 5.0 \text{ V}$ ,  $V_{DDIO} = \text{REFB}$ 

| Parameter                            | Symbol                | Minimum               | Typical | Maximum               | Units | Notes                                                                                        |
|--------------------------------------|-----------------------|-----------------------|---------|-----------------------|-------|----------------------------------------------------------------------------------------------|
| DC Supply Current in                 | I <sub>DD_RUN3</sub>  |                       | 33      | 45                    | mA    | Average current, including LASER                                                             |
| 3V mode                              | I <sub>DD_REST1</sub> |                       | 0.26    | 0.4                   | mA    | current. No load on MISO, MOTION.                                                            |
|                                      | I <sub>DD_REST2</sub> |                       | 0.12    | 0.2                   | mA    |                                                                                              |
|                                      | I <sub>DD_REST3</sub> |                       | 0.08    | 0.15                  | mA    |                                                                                              |
| DC Supply Current in 5V mode         | I <sub>DD_RUN5</sub>  |                       | 36      | 50                    | mA    |                                                                                              |
| Peak Supply Current                  | I <sub>DDP3</sub>     |                       |         | 60                    | mA    | For 3V mode                                                                                  |
|                                      | I <sub>DDP5</sub>     |                       |         | 65                    | mA    | For 5V mode                                                                                  |
| Shutdown Supply Current              | I <sub>DDSTDWN</sub>  |                       | 65      | 140                   | μΑ    | NCS, SCLK, MOSI = VDDIO<br>MISO = GND                                                        |
| REFB Output Voltage                  | $V_{REFB}$            | 2.85                  | 3.05    | 3.25                  | V     | Do not connect this pin as a supply to other chips other than the integrated VCSEL and VDDIO |
| Input Low Voltage                    | $V_{IL}$              |                       |         | 0.3*V <sub>DDIO</sub> | V     | SCLK, MOSI, NCS                                                                              |
| Input High Voltage                   | $V_{IH}$              | 0.7*V <sub>DDIO</sub> |         |                       | V     | SCLK, MOSI, NCS                                                                              |
| Input Hysteresis                     | $V_{I\_HYS}$          |                       | 100     |                       | mV    | SCLK, MOSI, NCS                                                                              |
| Input Leakage Current                | I <sub>leak</sub>     |                       | ±1      | ±10                   | μΑ    | Vin = 0.7*VDDIO , SCLK, MOSI, NCS                                                            |
| Output Low Voltage,<br>MISO, MOTION  | $V_{OL}$              |                       |         | 0.3*V <sub>DDIO</sub> | V     | lout = 1mA, MISO, MOTION                                                                     |
| Output High Voltage,<br>MISO, MOTION | V <sub>OH</sub>       | 0.7*V <sub>DDIO</sub> |         |                       | V     | lout = -1mA, MISO, MOTION                                                                    |
| Output Low Voltage,<br>LASER_NEN     | V <sub>OL</sub>       |                       |         | 0.3*V <sub>REFB</sub> | V     | lout = 1mA, LASER_NEN                                                                        |
| Output High Voltage,<br>LASER_NEN    | V <sub>OH</sub>       | 0.7*V <sub>REFB</sub> |         |                       | V     | lout = -0.5mA, LASER_NEN                                                                     |
| Input Capacitance                    | C <sub>in</sub>       |                       |         | 10                    | pF    | MOSI, NCS, SCLK                                                                              |

# **Sensor's Typical Performance Characteristics**



Figure 10. Mean Resolution vs. Z at default resolution at 1600cpi



Figure 11. Average Error vs. Distance at default resolution at 1600cpi (mm)



Figure 12. Wavelength Responsivity

## **Synchronous Serial Port**

The synchronous serial port is used to set and read parameters in the ADNS-9500 Sensor, and to read out the motion information. The serial port is also used to load PROM data into the ADNS-9500 Sensor.

The port is a four wire port. The host micro-controller always initiates communication; the ADNS-9500 Sensor never initiates data transfers. SCLK, MOSI, and NCS may be driven directly by a micro-controller. The port pins may be shared with other SPI slave devices. When the NCS pin is high, the inputs are ignored and the output is tri-stated.

The lines that comprise the SPI port are:

**SCLK:** Clock input. It is always generated by the master (the micro-controller).

MOSI: Input data. (Master Out/Slave In)

MISO: Output data. (Master In/Slave Out)

**NCS:** Chip select input (active low). **NCS** needs to be low to activate the serial port; otherwise, **MISO** will be high Z, and **MOSI** & **SCLK** will be ignored. **NCS** can also be used to reset the serial port in case of an error.

#### **Motion Pin**

The motion pin is an active low output that signals the micro-controller when motion has occurred. The motion pin is lowered whenever the motion bit is set; in other words, whenever there is data in the Delta\_X\_L, Delta\_XH, Delta\_Y\_L or Delta\_Y\_H registers. Clearing the motion bit (by reading Delta\_X\_L, Delta\_XH, Delta\_Y\_L and Delta\_Y\_H, or writing to the Motion register) will put the motion pin high.

## **Chip Select Operation**

The serial port is activated after NCS goes low. If NCS is raised during a transaction, the entire transaction is aborted and the serial port will be reset. This is true for all transactions including PROM download. After a transaction is aborted, the normal address-to-data or transaction-to-transaction delay is still required before beginning the next transaction. To improve communication reliability, all serial transactions should be framed by NCS. In other words, the port should not remain enabled during periods of non-use because ESD and EFT/B events could be interpreted as serial communication and put the chip into an unknown state. In addition, NCS must be raised after each burst-mode transaction is complete to terminate burst-mode. The port is not available for further use until burst-mode is terminated.

# **Write Operation**

Write operation, defined as data going from the microcontroller to the ADNS-9500 Sensor, is always initiated by the micro-controller and consists of two bytes. The first byte contains the address (seven bits) and has a "1" as its MSB to indicate data direction. The second byte contains the data. The ADNS-9500 Sensor reads MOSI on rising edges of SCLK.



Figure 13. Write Operation



Figure 14. MOSI Setup and Hold Time

## **Read Operation**

A read operation, defined as data going from the ADNS-9500 Sensor to the micro-controller, is always initiated by the micro-controller and consists of two bytes. The first byte contains the address, is sent by the micro-controller over MOSI, and has a "0" as its MSB to indicate data direction. The second byte contains the data and is driven by the ADNS-9500 Sensor over MISO. The sensor outputs MISO bits on falling edges of SCLK and samples MOSI bits on every rising edge of SCLK.



Figure 15. Read Operation



Figure 16. MISO Delay and Hold Time

#### NOTE:

The minimum high state of SCLK is also the minimum MISO data hold time of the ADNS-9500 Sensor. Since the falling edge of SCLK is actually the start of the next read or write command, the ADNS-9500 Sensor will hold the state of data on MISO until the falling edge of SCLK.

# Required timing between Read and Write Commands (tsxx)

There are minimum timing requirements between read and write commands on the serial port.



Figure 17. Timing between two write commands

If the rising edge of the SCLK for the last data bit of the second write command occurs before the tsww delay, then the first write command may not complete correctly.



Figure 18. Timing between write and read commands

If the rising edge of SCLK for the last address bit of the read command occurs before the tswr required delay, the write command may not complete correctly.



Figure 19. Timing between read and either write or subsequent read commands

During a read operation SCLK should be delayed at least tSRAD after the last address data bit to ensure that the Sensor has time to prepare the requested data.

The falling edge of SCLK for the first address bit of either the read or write command must be at least TSRR or TSRW after the last SCLK rising edge of the last data bit of the previous read operation. In addition, during a read operation SCLK should be delayed after the last address data bit to ensure that the ADNS-9500 Sensor has time to prepare the requested data.

## **Burst Mode Operation**

Burst mode is a special serial port operation mode which may be used to reduce the serial transaction time for three predefined operations: motion read, PROM download and frame capture. The speed improvement is achieved by continuous data clocking to or from multiple registers without the need to specify the register address, and by not requiring the normal delay period between data bytes.

#### **Motion Burst Read**

Reading the Motion\_Burst register activates this mode. The ADNS-9500 sensor will respond with the contents of the Motion, Observation, Delta\_X\_L, Delta\_X\_H, Delta\_Y\_L, Delta\_Y\_H, Pixel Statistic, Shutter and Frame period registers in that order. After sending the register address, the micro-controller must wait one frame, and then begin reading data. All data bits can be read with no delay between bytes by driving SCLK at the normal rate. The data are latched into the output buffer after the last address bit is received. After the burst transmission is complete, the micro-controller must raise the NCS line for at least tBEXIT to terminate burst mode. The serial port is not available for use until it is reset with NCS, even for a second burst transmission.



Figure 20. Motion Burst Timing

#### Procedure to start motion burst:

- 1. Lower NCS
- 2. Send 0x50 to Motion\_Burst register.
- 3. Wait for one frame. (This only applicable in Run mode for wakeup but not require for rest mode)
- Start reading SPI Data continuously up to 14bytes. Motion burst may be terminated by pulling NCS high for at least t<sub>BFXIT</sub>.
- 5. To read new motion burst data, repeating from step 1.
- 6. Write any value to Motion register (address 0x02) to clear any residual motion.

### Motion burst reporting:

BYTE [00] = Motion

BYTE [01] = Observation

BYTE [02] = Delta\_X\_L

BYTE [03] = Delta\_X\_H

BYTE [04] = Delta\_Y\_L

BYTE [05] = Delta Y H

BYTE [06] = SQUAL

BYTE [07] = Pixel Sum

BYTE [08] = Maximum\_Pixel

BYTE [09] = Minimum Pixel

BYTE [10] = Shutter Upper

bi it [io] = Siluttei\_oppei

BYTE [11] = Shutter\_Lower BYTE [12] = Frame Period Upper

BYTE [13] = Frame Period Lower

Note: In rest mode, motion burst data is always available or in other words, motion burst data can be read from Motion\_Burst register even in rest modes.

#### **SROM Download**

This function is used to load the Avago supplied firmware file contents into the ADNS-9500 after sensor power up sequence. The firmware file is an ASCII text file. There are 2 methods of SROM downloading in ADNS-9500:1.5K and 3K bytes. 1.5K SROM download will only download 1.5K bytes data into the first half of SROM and leave the rest empty, while 3K SROM download will download the full 3K bytes data into SROM. They can be selected through Configuration\_IV register, where default setting is 1.5K SROM download. In the current version of ADNS-9500 sensor, 3K bytes of SROM will be used.

#### SROM download procedure:

- Select the 3K bytes SROM size at Configuration\_IV register, address 0x39
- 2. Write 0x1d to SROM\_Enable register for initializing
- 3. Wait for one frame
- 4. Write 0x18 to SROM\_Enable register again to start SROM downloading
- Write SROM file into SROM\_Load\_Burst register, 1st data must start with SROM\_Load\_Burst register address. All the SROM data must be downloaded before SROM start running.



Figure 21. SROM Download Burst Mode

# **Frame Capture**

This is a fast way to download a full array of pixel values from a single frame. This mode disables navigation and overwrites any downloaded firmware. A hardware reset is required to restore navigation, and the SROM firmware must be reloaded.

To trigger the capture, write to the Frame\_Capture register. The next available complete 1 frame image will be stored to memory. The data are retrieved by reading the Pixel\_Burst register once using the normal read method, after which the remaining bytes are clocked out by driving SCLK at the normal rate. If the Pixel\_Burst register is read before the data is ready, it will return all zeros.

Procedure of Frame Capture:

- 1. Reset the chip by writing 0x5a to Power\_Up\_Reset register (address 0x3a).
- 2. Enable laser by setting Forced\_Disable bit (bit-0) of LASER\_CTRL0 register to 0.
- 3. Write 0x93 to Frame\_Capture register.
- 4. Write 0xc5 to Frame\_Capture register.
- 5. Wait for two frames.
- 6. Check for first pixel by reading bit zero of Motion register. If =1, first pixel is available.
- 7. Continue read from Pixel\_Burst register until all 900 pixels are transferred.
- 8. Continue step 3-7 to capture another frame.

Note: Manual reset and SROM download are needed after frame capture to restore navigation for motion reading.



Figure 22. Frame Capture Burst Mode



Figure 23. Pixel Map (Surface referenced)

## **Power Up**

The ADNS-9500 Sensor does not perform an internal power up self-reset; the Power\_Up\_Reset register must be written every time power is applied. The appropriate sequence is as follows:

- 1. Apply power to VDD5/VDD3 and VDDIO in any order
- 2. Drive NCS high, and then low to reset the SPI port.
- 3. Write 0x5a to Power\_Up\_Reset register (address 0x3a).
- 4. Wait for at least 50ms time.

- 5. Read from registers 0x02, 0x03, 0x04, 0x05 and 0x06 (or read these same 5 bytes from burst motion register) one time regardless of the motion pin state.
- 6. SROM download.
- 7. Enable laser by setting Forced\_Disable bit (bit-0) of LASER\_CTRL0 register (address 0x20) to 0.

During power-up there will be a period of time after the power supply is high but before any clocks are available. The table below shows the state of the various pins during power-up and reset.

## State of Signal Pins After VDD is Valid

| Pin       | On Power-Up | NCS High before Reset | NCS Low before Reset | After Reset    |
|-----------|-------------|-----------------------|----------------------|----------------|
| NCS       | Functional  | Hi                    | Low                  | Functional     |
| MISO      | Undefined   | Undefined             | Functional           | Depends on NCS |
| SCLK      | Ignored     | Ignored               | Functional           | Depends on NCS |
| MOSI      | Ignored     | Ignored               | Functional           | Depends on NCS |
| MOTION    | Undefined   | Undefined             | Undefined            | Functional     |
| LASER_NEN | Undefined   | Undefined             | Undefined            | Functional     |

#### Shutdown

The ADNS-9500 can be set in Shutdown mode by writing 0xb6 to register 0x3b. The SPI port should not be accessed when Shutdown mode is asserted, except the power-up command (writing 0x5a to register 0x3a). (Other ICs on the same SPI bus can be accessed, as long as the sensor's NCS pin is not asserted.) The table below shows the state of various pins during shutdown. To deassert Shutdown mode:

- 1. Drive NCS high, then low to reset the SPI port.
- 2. Write 0x5a to Power\_Up\_Reset register (address 0x3a).
- 3. Wait for at least 50ms time.
- 4. Clear observation register.
- 5. Wait at least one frame and check observation register, Bit[5:0] must be set.
- 6. Read from registers 0x02, 0x03, 0x04, 0x05 and 0x06 (or read these same 5 bytes from burst motion register) one time regardless of the motion pin state.
- 7. SROM download.
- 8. Enable laser by setting Forced\_Disable bit (bit-0) of LASER\_CTRL0 register to 0.
- 9. Any register setting must then be reloaded.

| Pin       | Status when Shutdown Mode |
|-----------|---------------------------|
| NCS       | Functional *1             |
| MISO      | Undefined *2              |
| SCLK      | Ignore if NCS = $1*3$     |
| MOSI      | Ignore if NCS = 1 *4      |
| LASER_NEN | High (off)                |
| MOTION    | Undefined *2              |

- \*1 NCS pin must be held to 1 (high) if SPI bus is shared with other devices. It is recommended to hold to 1 (high) during Power Down unless powering up the Sensor. It must be held to 0 (low) if the sensor is to be re-powered up from shutdown (writing 0x5a to register 0x3a).
- \*2 Depends on last state. MISO should be configured to drive LOW during shutdown to meet the low current consumption as specified in the datasheet. This can be achieved by reading Inverse\_Product\_ ID register (address 0x3f) since the return value (0xcc) on MISO line ends in a 0 (low state).
- \*3 SCLK is ignored, if NCS is 1 (high). It is functional if NCS is 0 (low).
- \*4 MOSI is ignored, if NCS is 1 (high). If NCS is 0 (low), any command present on the MOSI pin will be ignored except power-up command (writing 0x5a to register 0x3a).

#### Note

There are long wakeup times from shutdown and forced Rest. These features should not be used for power management during normal mouse motion.

# Registers

The ADNS-9500 registers are accessible via the serial port. The registers are used to read motion data and status as well as to set the device configuration.

| Address     | Register                     | Read/Write | Default Value |
|-------------|------------------------------|------------|---------------|
| 0x00        | Product_ID                   | R          | 0x33          |
| 0x01        | Revision_ID                  | R          | 0x03          |
| 0x02        | Motion                       | R          | 0x00          |
| 0x03        | Delta_X_L                    | R          | 0x00          |
| 0x04        | Delta_X_H                    | R          | 0x00          |
| 0x05        | Delta_Y_L                    | R          | 0x00          |
| 0x06        | Delta_Y_H                    | R          | 0x00          |
| 0x07        | SQUAL                        | R          | 0x00          |
| 0x08        | Pixel_Sum                    | R          | 0x00          |
| 0x09        | Maximum_Pixel                | R          | 0x00          |
| 0x0a        | Minimum_Pixel                | R          | 0x00          |
| 0x0b        | Shutter_Lower                | R          | 0x20          |
| 0x0c        | Shutter_Upper                | R          | 0x4e          |
| 0x0d        | Frame_Period_Lower           | R          | 0xc0          |
| 0x0e        | Frame_Period_Upper           | R          | 0x5d          |
| 0x0f        | Configuration_I              | R/W        | 0x12          |
| 0x10        | Configuration_II             | R/W        | 0x00          |
| 0x12        | Frame_Capture                | R/W        | 0x00          |
| 0x13        | SROM_Enable                  | W          | 0x00          |
| 0x14        | Run_Downshift                | R/W        | 0x32          |
| 0x15        | Rest1_Rate                   | R/W        | 0x01          |
| 0x16        | Rest1_Downshift              | R/W        | 0x1f          |
| 0x17        | Rest2_Rate                   | R/W        | 0x09          |
| 0x18        | Rest2_Downshift              | R/W        | 0xbc          |
| 0x19        | Rest3_Rate                   | R/W        | 0x31          |
| 0x1a        | Frame_Period_Max_Bound_Lower | R/W        | 0xc0          |
| 0x1b        | Frame_Period_Max_Bound_Upper | R/W        | 0x5d          |
| 0x1c        | Frame_Period_Min_Bound_Lower | R/W        | 0xa0          |
| 0x1d        | Frame_Period_Min_Bound_Upper | R/W        | 0x0f          |
| 0x1e        | Shutter_Max_Bound_Lower      | R/W        | 0x20          |
| 0x1f        | Shutter_Max_Bound_Upper      | R/W        | 0x4e          |
| 0x20        | LASER_CTRL0                  | R/W        | 0x01          |
| 0x21- 0x23  | Reserved                     |            |               |
| 0x24        | Observation                  | R/W        | 0x00          |
| 0x25        | Data_Out_Lower               | R          | Undefined     |
| 0x26        | Data_Out_Upper               | R          | Undefined     |
| 0x27 - 0x29 | Reserved                     |            |               |
| 0x2a        | SROM_ID                      | R          | 0x00          |
| 0x2e        | <br>Lift_Detection_Thr       | R/W        | 0x10          |
| 0x2f        | <br>Configuration_V          | R/W        | 0x12          |
| 0x30 - 0x38 | Reserved                     |            |               |
| 0x39        | Configuration_IV             | R/W        | 0x00          |
| 0x3a        | Power_Up_Reset               | W          | NA            |
| 0x3b        | Shutdown                     | W          | Undefined     |
| 0x3c - 0x3e | Reserved                     |            |               |
| 0x3f        | Inverse_Product_ID           | R          | 0хсс          |
| 0x40 – 0x4f | Reserved                     |            |               |
| 0x50        | Motion_Burst                 | R          | 0x00          |
| 0x62        | SROM_Load_Burst              | W          | Undefined     |
| 0x64        | Pixel_Burst                  | R          | 0x00          |
| UU I        | . I/ICI_DOI30                |            | 0,000         |

| Product_ID Access: Read Only |                  |                  |                  | Address: 0x00<br>Reset Value: 0x33 |                  |                  |                  |                  |
|------------------------------|------------------|------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|
| Bit                          | 7                | 6                | 5                | 4                                  | 3                | 2                | 1                | 0                |
| Field                        | PID <sub>7</sub> | PID <sub>6</sub> | PID <sub>5</sub> | PID <sub>4</sub>                   | PID <sub>3</sub> | PID <sub>2</sub> | PID <sub>1</sub> | PID <sub>0</sub> |

Data Type: 8-bit unsigned integer.

USAGE: This value is a unique identification assigned to this model only. The value in this register does not change; it can be used to verify that the serial communications link is functional.

| Revision_ID Access: Read Only |                  |                  |                  | Address: 0x01<br>Reset Value: 0x03 |                  |                  |                  |                  |  |
|-------------------------------|------------------|------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|--|
| Bit                           | 7                | 6                | 5                | 4                                  | 3                | 2                | 1                | 0                |  |
| Field                         | RID <sub>7</sub> | RID <sub>6</sub> | RID <sub>5</sub> | RID <sub>4</sub>                   | RID <sub>3</sub> | RID <sub>2</sub> | RID <sub>1</sub> | RID <sub>0</sub> |  |

Data Type: 8-bit unsigned integer.

USAGE: This register contains the current IC revision, the revision of the permanent internal firmware. It is subject to change when new IC versions are released.

| Motion<br>Access: Read Only |     |       |          | Address: 0x02<br>Reset Value: 0x00 |          |                      |                      |                     |  |
|-----------------------------|-----|-------|----------|------------------------------------|----------|----------------------|----------------------|---------------------|--|
| Bit                         | 7   | 6     | 5        | 4                                  | 3        | 2                    | 1                    | 0                   |  |
| Field                       | MOT | FAULT | LP_Valid | Reserved                           | Reserved | OP_Mode <sub>1</sub> | OP_Mode <sub>2</sub> | FRAME_<br>Pix_First |  |

Data Type: Bit field

USAGE: Register 0x02 allows the user to determine if motion has occurred since the last time it was read. If the MOT bit is set, Delta\_X\_L, Delta\_X\_H, Delta\_Y\_L and Delta\_Y\_H register should be read in sequence to get the accumulated motion. Read this register before reading the Delta\_X\_L, Delta\_X\_H, Delta\_Y\_L and Delta\_Y\_H registers as reading this register freezes the Delta\_X\_L, Delta\_X\_H, Delta\_Y\_L and Delta\_Y\_H register values. If Delta\_X\_L, Delta\_X\_H, Delta\_Y\_L and Delta\_Y\_H registers are not read before the Motion register is read for the second time, the data in Delta\_X\_L, Delta\_X\_H, Delta\_Y\_L and Delta\_Y\_H will be lost. Writing anything to this register clears the MOT bit, Delta\_X\_L, Delta\_X\_H, Delta\_Y\_L and Delta\_Y\_H registers. The written data byte is not saved.

It also tells if laser fault, laser power setting status and operating mode in current frame.

| Field Name      | Description                                                                                                                                                 |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOT             | Motion since last report or Shutdown  0 = No motion  1 = Motion occurred, data ready for reading in Delta_X_L, Delta_X_H, Delta_Y_L and Delta_Y_H registers |
| FAULT           | Indicates that the XY_LASER is shorted to GND. <b>0</b> = no fault detected  1 = fault detected                                                             |
| LP_Valid        | Laser Power Settings  0 = Laser power register values do not have complementary values  1 = laser power is valid                                            |
| OP_Mode[1:0]    | Operating mode of the sensor <b>00 = Run</b> 01 = Rest 1  10 = Rest 2  11 = Rest 3                                                                          |
| FRAME_Pix_First | This bit is set to indicate first pixel in frame capture. <b>0 = Frame capture data not from pixel 0,0</b> 1 = Frame capture data is from pixel 0,0         |

| Delta_X_L<br>Access: Read Only |                |                |                | Address: 0x03<br>Reset Value: 0x00 |                |                |                |                |  |
|--------------------------------|----------------|----------------|----------------|------------------------------------|----------------|----------------|----------------|----------------|--|
| Bit                            | 7              | 6              | 5              | 4                                  | 3              | 2              | 1              | 0              |  |
| Field                          | X <sub>7</sub> | X <sub>6</sub> | X <sub>5</sub> | X <sub>4</sub>                     | X <sub>3</sub> | X <sub>2</sub> | X <sub>1</sub> | X <sub>0</sub> |  |

Data Type: 16 bits 2's complement number. Lower 8 bits of Delta\_X.

USAGE: X movement is counts since last report. Absolute value is determined by resolution. Reading it clears the register.



| Delta_X_H<br>Access: Read Only |                 |                 |                 | Address: 0x04<br>Reset Value: 0x00 |                 |                 |                |                |  |
|--------------------------------|-----------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|----------------|----------------|--|
| Bit                            | 7               | 6               | 5               | 4                                  | 3               | 2               | 1              | 0              |  |
| Field                          | X <sub>15</sub> | X <sub>14</sub> | X <sub>13</sub> | X <sub>12</sub>                    | X <sub>11</sub> | X <sub>10</sub> | X <sub>9</sub> | X <sub>8</sub> |  |

Data Type: 16 bits 2's complement number. Upper 8 bits of Delta\_X.

USAGE: Delta\_X\_H must be read after Delta\_X\_L to have the full motion data. Reading it clears the register.

| Delta_Y_L<br>Access: Read Only |                |                | Address: 0x05<br>Reset Value: 0x00 |                |                |                |                |                |  |
|--------------------------------|----------------|----------------|------------------------------------|----------------|----------------|----------------|----------------|----------------|--|
| Bit                            | 7              | 6              | 5                                  | 4              | 3              | 2              | 1              | 0              |  |
| Field                          | Y <sub>7</sub> | Y <sub>6</sub> | Y <sub>5</sub>                     | Y <sub>4</sub> | Y <sub>3</sub> | Y <sub>2</sub> | Y <sub>1</sub> | Y <sub>0</sub> |  |

Data Type: 16 bits 2's complement number. Lower 8 bits of Delta\_Y.

USAGE: Y movement is counts since last report. Absolute value is determined by resolution. Reading it clears the register.



| Delta_Y_H<br>Access: Read Only |                 |                 | Address: 0x06<br>Reset Value: 0x00 |                 |                 |                 |                |                |  |
|--------------------------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|----------------|----------------|--|
| Bit                            | 7               | 6               | 5                                  | 4               | 3               | 2               | 1              | 0              |  |
| Field                          | Y <sub>15</sub> | Y <sub>14</sub> | Y <sub>13</sub>                    | Y <sub>12</sub> | Y <sub>11</sub> | Y <sub>10</sub> | Y <sub>9</sub> | Y <sub>8</sub> |  |

Data Type: 16 bits 2's complement number. Upper 8 bits of Delta\_Y.

USAGE: Delta\_Y\_H must be read after Delta\_Y\_L to have the full motion data. Reading it clears the register.

| SQUAL<br>Access: Read Only |                 |                 |                 | Address: 0x07<br>Reset Value: 0x00 |                 |                 |                 |                 |  |
|----------------------------|-----------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|-----------------|--|
| Bit                        | 7               | 6               | 5               | 4                                  | 3               | 2               | 1               | 0               |  |
| Field                      | SQ <sub>7</sub> | SQ <sub>6</sub> | SQ <sub>5</sub> | SQ <sub>4</sub>                    | SQ <sub>3</sub> | SQ <sub>2</sub> | SQ <sub>1</sub> | SQ <sub>0</sub> |  |

Data Type: Upper 8-bits of a 10-bit unsigned integer.

USAGE: The SQUAL (Surface quality) register is a measure of the number of valid features visible by the sensor in the current frame. Use the following formula to find the total number of valid features.

Number of Features = SQUAL Register Value \* 4

The maximum SQUAL register value is 169. Since small changes in the current frame can result in changes in SQUAL, variations in SQUAL when looking at a surface are expected. The graph below shows 800 sequentially acquired SQUAL values, while a sensor was moved slowly over white paper. SQUAL is nearly equal to zero if there is no surface below the sensor. SQUAL remains fairly high throughout the Z-height range which allows illumination of most pixels in the sensor.



Figure 24. SQUAL Values at 1600cpi (White Paper)



Figure 25. Mean SQUAL vs. Z (White Paper)

| Pixel_Sum<br>Access: Read Only |                 |                 | Address: 0x08<br>Reset Value: 0x00 |                 |                 |                 |                 |                 |
|--------------------------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| Bit                            | 7               | 6               | 5                                  | 4               | 3               | 2               | 1               | 0               |
| Field                          | AP <sub>7</sub> | AP <sub>6</sub> | AP <sub>5</sub>                    | AP <sub>4</sub> | AP <sub>3</sub> | AP <sub>2</sub> | AP <sub>1</sub> | AP <sub>0</sub> |

Data Type: High 8-bits of an unsigned 17-bit integer.

USAGE: This register is used to find the average pixel value. It reports the upper byte of a 17-bit counter which sums all 900 pixels in the current frame. It may be described as the full sum divided by 512. To find the average pixel value, follows the formula below.

Average Pixel = Register Value \* 512/900 ≅ Register Value/1.76

The maximum register value is 223 (127 \* 900/512 truncated to an integer). The minimum register value is 0. The pixel sum value can change every frame.

| Maximum_Pixel Access: Read Only |                 |                 | Address: 0x09<br>Reset Value: 0x00 |                 |                 |                 |                 |                 |  |
|---------------------------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|--|
| Bit                             | 7               | 6               | 5                                  | 4               | 3               | 2               | 1               | 0               |  |
| Field                           | MP <sub>7</sub> | MP <sub>6</sub> | MP <sub>5</sub>                    | MP <sub>4</sub> | MP <sub>3</sub> | MP <sub>2</sub> | MP <sub>1</sub> | MP <sub>0</sub> |  |

Data Type: Seven bit number.

USAGE: Maximum Pixel value in current frame. Minimum value = 0, maximum value = 127. The maximum pixel value can be adjusted every frame.

| Minimum_Pixel Access: Read Only |                   |                   | Address: 0x0A<br>Reset Value: 0x00 |                   |                   |                   |                   |                   |
|---------------------------------|-------------------|-------------------|------------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|
| Bit                             | 7                 | 6                 | 5                                  | 4                 | 3                 | 2                 | 1                 | 0                 |
| Field                           | MinP <sub>7</sub> | MinP <sub>6</sub> | MinP <sub>5</sub>                  | MinP <sub>4</sub> | MinP <sub>3</sub> | MinP <sub>2</sub> | MinP <sub>1</sub> | MinP <sub>0</sub> |

Data Type: Seven bit number.

USAGE: Minimum Pixel value in current frame. Minimum value = 0, maximum value = 127. The maximum pixel value can be adjusted every frame.

| Shutter_Lower<br>Access: Read Only |                |                |                | Address: 0x0B<br>Reset Value: 0x20 |                |                |                |                |  |
|------------------------------------|----------------|----------------|----------------|------------------------------------|----------------|----------------|----------------|----------------|--|
| Bit                                | 7              | 6              | 5              | 4                                  | 3              | 2              | 1              | 0              |  |
| Field                              | S <sub>7</sub> | S <sub>6</sub> | S <sub>5</sub> | S <sub>4</sub>                     | S <sub>3</sub> | S <sub>2</sub> | S <sub>1</sub> | S <sub>0</sub> |  |

| Shutter_Upper<br>Access: Read Only |                 |                 | Address: 0x0C<br>Reset Value: 0x4e |                 |                 |                 |                |                |  |
|------------------------------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|----------------|----------------|--|
| Bit                                | 7               | 6               | 5                                  | 4               | 3               | 2               | 1              | 0              |  |
| Field                              | S <sub>15</sub> | S <sub>14</sub> | S <sub>13</sub>                    | S <sub>12</sub> | S <sub>11</sub> | S <sub>10</sub> | S <sub>9</sub> | S <sub>8</sub> |  |

Data Type: 16-bit unsigned number.

USAGE: Units are clock cycles of internal oscillator (nominally 47MHz). Read Shutter\_Upper first, then Shutter\_Lower. They should be read consecutively. The shutter is adjusted to keep the average pixel values within normal operating ranges. The shutter value is checked and automatically adjusted to a new value if needed on every frame when operating in default mode. The shutter value can be set manually by disabling the AGC using the Configuration\_II register and writing to the Shutter\_Maximum\_Bound registers. Because the automatic frame rate feature is related to shutter value it may also be appropriate to enable the fixed frame rate mode using the Configuration\_II register. The maximum value of the shutter is dependent upon the setting in the Shutter\_Maximum\_Bound registers.

Shown below is a graph of 800 sequentially acquired shutter values, while the sensor was moved slowly over white paper.



Figure 26. Shutter Values at 5670cpi (White Paper)



Figure 27. Mean Shutter vs. Z (White Paper)

| Frame_Period_Lower Access: Read Only |                 |                 | Address: 0x0D<br>Reset Value: 0xc0 |                 |                 |                 |                 |                 |  |
|--------------------------------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|--|
| Bit                                  | 7               | 6               | 5                                  | 4               | 3               | 2               | 1               | 0               |  |
| Field                                | FP <sub>7</sub> | FP <sub>6</sub> | FP <sub>5</sub>                    | FP <sub>4</sub> | FP <sub>3</sub> | FP <sub>2</sub> | FP <sub>1</sub> | FP <sub>0</sub> |  |

| Frame_Peri<br>Access: Re |                  |                  | Address:<br>Reset Val |                  |                  |                  |                 |                 |  |
|--------------------------|------------------|------------------|-----------------------|------------------|------------------|------------------|-----------------|-----------------|--|
| Bit                      | 7                | 6                | 5                     | 4                | 3                | 2                | 1               | 0               |  |
| Field                    | FP <sub>15</sub> | FP <sub>14</sub> | FP <sub>13</sub>      | FP <sub>12</sub> | FP <sub>11</sub> | FP <sub>10</sub> | FP <sub>9</sub> | FP <sub>8</sub> |  |

Data Type: 16-bit unsigned integer.

USAGE: To read from the registers, read Frame\_Period\_Upper first followed by Frame\_Period\_Lower. If the Frame\_Period\_Upper register greater the zero, these registers provide the Run mode frame rate period. Read these registers to determine the run mode frame period, or indirectly the run mode frame rate. Units are clock cycles of the internal oscillator (nominally 47MHz). The formula is:

Run Mode's Frame Rate = Clock Frequency/Register Value

If the Frame\_Period\_Upper register is zero, these register provide the Rest mode frame rate period. Read these register to determine the rest mode frame period, or indirectly the rest mode frame rate. Units are clock cycles of the internal oscillator (nominally 100Hz). The formula is:

Rest Mode Frame Rate = 1 / [Register Value + 1]

To set the frame rate manually, disable automatic frame rate mode via the Configuration\_II register and write the desired count value to the Frame\_Period\_Maximum\_Bound registers.

| Configuration_I<br>Access: R/W |          |          | Address: 0x0F<br>Reset Value: 0x12 |                  |                  |                  |                  |                  |  |
|--------------------------------|----------|----------|------------------------------------|------------------|------------------|------------------|------------------|------------------|--|
| Bit                            | 7        | 6        | 5                                  | 4                | 3                | 2                | 1                | 0                |  |
| Field                          | Reserved | Reserved | RES <sub>5</sub>                   | RES <sub>4</sub> | RES <sub>3</sub> | RES <sub>2</sub> | RES <sub>1</sub> | RES <sub>0</sub> |  |

Data Type: Bit Field.

USAGE: This register sets the resolution on XY axes or X axis only. The approximate resolution value for each register setting can be calculated using the following formula. Each bit change is ~90cpi. The maximum write value is 0x38, which the resolution setting is approximately 5670cpi.

Resolution value (counts per inch, cpi)  $\approx$  RES [5:0] x 90

For example:

| Configuration_I<br>Register Value | Approximate<br>Resolution (cpi) | Description |
|-----------------------------------|---------------------------------|-------------|
| 0x01                              | 90                              | Minimum     |
| 0x12                              | 1620                            | Default     |
| 0x24                              | 3240                            |             |
| 0x38                              | 5040                            | Maximum     |

Note: Rpt\_Mod bit in Configuration\_II register is used to select CPI reporting mode either XY axes resolution setting in sync or independent setting for X-axis and Y-axis respectively. Refer to Configuration\_V register for Y-axis resolution setting.

| Configuration_II Access: R/W |                     |                     | Address: 0x10<br>Reset Value: 0x00 |      |          |         |   |   |
|------------------------------|---------------------|---------------------|------------------------------------|------|----------|---------|---|---|
| Bit                          | 7                   | 6                   | 5                                  | 4    | 3        | 2       | 1 | 0 |
| Field                        | F_Rest <sub>1</sub> | F_Rest <sub>0</sub> | Rest_En                            | NAGC | Fixed_FR | Rpt_Mod | 0 | 0 |

Data Type: Bit Field.

USAGE: This register is used to change configuration of sensor.

When the sensor is put into Force Rest function via F\_Rest[1:0], the operation mode of sensor will change from current mode to the next desired Rest mode and stay at the desired Rest mode until the Force Rest mode is released. Once Force Rest mode is released, the sensor will resume to normal operation from the desired Rest mode and auto downshift to the next level of Rest modes if no motion or recover to Run mode if motion is detected.

## For example:

|              | Next desired | Force Rest mode                 |                                                                                                                                             |
|--------------|--------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Current mode | mode         | action                          | After Force Rest mode is released $(F_Rest[1:0] = 00)$                                                                                      |
| Run          | Rest1        | Force Rest1<br>F_Rest[1:0] = 01 | Resume to normal operation from REST1, auto downshift to Rest2, then Rest3 in sequence if no motion or back to Run mode if motion detected. |
| Run          | Rest2        | Force Rest2<br>F_Rest[1:0] = 10 | Resume to normal operation from REST2, auto downshift to Rest3 if no motion or back to Run mode if motion detected.                         |
| Run          | Rest3        | Force Rest3<br>F_Rest[1:0] = 11 | Resume to normal operation from REST3, stay in Rest3 if no motion or back to Run mode if motion detected.                                   |

| Field Name  | Description                                                                                                                                                                                                                    |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F_Rest[1:0] | Puts chip into Rest mode  00 = Normal operation  01 = Force Rest1  10 = Force Rest2  11 = Force Rest3                                                                                                                          |
| Rest_En     | Enable Rest mode  0 = Normal operation without REST modes  1 = REST modes enabled                                                                                                                                              |
| NAGC        | Disable AGC. Shutter value will be set to the value in the Shutter_Maximum_Bound registers.  0 = no, AGC is active  1 = yes, AGC is disabled                                                                                   |
| Fixed_FR    | Fixed frame rate (disable automatic frame rate control). When this bit is set the frame rate will be set by the value in the Frame_Period_Maximum_Bound registers.  0 = automatic frame rate 1 = fixed frame rate              |
| Rpt_Mod     | Select CPI reporting mode. <b>0 = XY axes CPI setting in sync</b> 1 = CPI setting independently for X-axis and Y-axis. Configuration_I register sets X-axis resolution, while Configuration_V register sets Y-axis resolution. |
| Bit[1:0]    | Must be set to 00                                                                                                                                                                                                              |

| Frame_Capture<br>Access: R/W |                 |                 |                 | Address: 0x12<br>Reset Value: 0x00 |                 |                 |                 |                 |   |  |  |
|------------------------------|-----------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|-----------------|---|--|--|
| Bit                          | 7               | 6               | 5               | 4                                  | 3               | 2               | 1               | 0               | - |  |  |
| Field                        | FC <sub>7</sub> | FC <sub>6</sub> | FC <sub>5</sub> | FC <sub>4</sub>                    | FC <sub>3</sub> | FC <sub>2</sub> | FC <sub>1</sub> | FC <sub>0</sub> |   |  |  |

Data Type: Bit Field.

USAGE: Used to capture the next available complete 1 frame of pixel values to be stored to SROM RAM. Writing to this register will cause any firmware loaded in the SROM to be overwritten and stops navigation. A hardware reset and SROM download are required to restore normal operation for motion reading. Refer to Frame Capture section for use details.

| SROM_Enable Access: Write Only |                 |                 |                 | Address: 0x13<br>Reset Value: 0x00 |                 |                 |                 |                 |  |  |
|--------------------------------|-----------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|-----------------|--|--|
| Bit                            | 7               | 6               | 5               | 4                                  | 3               | 2               | 1               | 0               |  |  |
| Field                          | SE <sub>7</sub> | SE <sub>6</sub> | SE <sub>5</sub> | SE <sub>4</sub>                    | SE <sub>3</sub> | SE <sub>2</sub> | SE <sub>1</sub> | SE <sub>0</sub> |  |  |

Data Type: 8 Bit number.

USAGE: Write to this register to start either SROM download or SROM CRC test. See SROM Download section for details SROM download procedure.

SROM CRC test can be performed to check for the successful of SROM downloading procedure. SROM CRC test is only valid after SROM downloaded. Navigation is halted and the SPI port should not be used during this SROM CRC test. Avago recommends reading the Motion register to determine the laser fault condition before performing the SROM CRC test.

SROM CRC test procedure is as below:

- 1. Write 0x15 to SROM\_Enable register to start SROM CRC test.
- 2. Wait for at least 10ms.
- 3. Read the CRC value from Data\_Lower and Data\_Upper registers.

| Run_Downshift<br>Access: R/W | :               |                 | Address:<br>Reset Val |                 |                 |                 |                 |                 |  |
|------------------------------|-----------------|-----------------|-----------------------|-----------------|-----------------|-----------------|-----------------|-----------------|--|
| Bit                          | 7               | 6               | 5                     | 4               | 3               | 2               | 1               | 0               |  |
| Field                        | RD <sub>7</sub> | RD <sub>6</sub> | RD <sub>5</sub>       | RD <sub>4</sub> | RD <sub>3</sub> | RD <sub>2</sub> | RD <sub>1</sub> | RD <sub>0</sub> |  |

Data Type: 8 Bit number.

USAGE: This register set the Run to Rest 1 downshift time. Default value is 500ms. Use the formula below for calculation.

Run Downshift time (ms) =  $RD[7:0] \times 10$ 

Default =  $50 \times 10 = 500 \text{ms}$ 

All the above values are calculated base on system clock, which expected to have 20% tolerance.

| Rest1_Rate<br>Access: R/W |                  |                  | Address: 0x15<br>Reset Value: 0x01 |                  |                  |                  |                  |                  |  |
|---------------------------|------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|------------------|--|
| Bit                       | 7                | 6                | 5                                  | 4                | 3                | 2                | 1                | 0                |  |
| Field                     | R1R <sub>7</sub> | R1R <sub>6</sub> | R1R <sub>5</sub>                   | R1R <sub>4</sub> | R1R <sub>3</sub> | R1R <sub>2</sub> | R1R <sub>1</sub> | R1R <sub>0</sub> |  |

Data Type: 8 Bit number.

USAGE: This register set the Rest 1 frame rate. Default value is 20ms. Use the formula below for calculation.

Rest1 frame rate =  $(R1R[7:0] + 1) \times 10ms$ .

Default =  $(1 + 1) \times 10 = 20 \text{ms}$ 

All the above values are calculated base on 100Hz Hibernate clock, which expected to have 40% tolerance.

|       | Rest1_Downshift Access: R/W |                  |                  | Address: 0x16<br>Reset Value: 0x1f |                  |                  |                  |                  |  |  |
|-------|-----------------------------|------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|--|--|
| Bit   | 7                           | 6                | 5                | 4                                  | 3                | 2                | 1                | 0                |  |  |
| Field | R1D <sub>7</sub>            | R1D <sub>6</sub> | R1D <sub>5</sub> | R1D <sub>4</sub>                   | R1D <sub>3</sub> | R1D <sub>2</sub> | R1D <sub>1</sub> | R1D <sub>0</sub> |  |  |

Data Type: 8 Bit number.

USAGE: This register set the Rest 1 to Rest 2 downshift time. Default value is 9920ms. Use the formula below for calculation.

Rest1 Downshift time =  $R1D[7:0] \times 16 \times Rest1$ \_Rate.

Default = 31 x 16 x 20 = 9920ms

All the above values are calculated base on 100Hz Hibernate clock, which expected to have 40% tolerance.

| Rest2_Rate<br>Access: R/W |                  |                  | Address: 0x17<br>Reset Value: 0x09 |                  |                  |                  |                  |                  |  |  |
|---------------------------|------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|------------------|--|--|
| Bit                       | 7                | 6                | 5                                  | 4                | 3                | 2                | 1                | 0                |  |  |
| Field                     | R2R <sub>7</sub> | R2R <sub>6</sub> | R2R <sub>5</sub>                   | R2R <sub>4</sub> | R2R <sub>3</sub> | R2R <sub>2</sub> | R2R <sub>1</sub> | R2R <sub>0</sub> |  |  |

Data Type: 8 Bit number.

USAGE: This register set the Rest 2 frame rate. Default value is 100ms. Use the formula below for calculation.

Rest2 frame rate =  $(R2R[7:0] + 1) \times 10ms$ .

Default =  $(9 + 1) \times 10 = 100 \text{ms}$ 

All the above values are calculated base on 100Hz Hibernate clock, which expected to have 40% tolerance.

| Rest2_Downshift<br>Access: R/W |                  | Address: 0x18<br>Reset Value: 0xbc |                  |                  |                  |                  |                  |                  |  |
|--------------------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|------------------|------------------|--|
| Bit                            | 7                | 6                                  | 5                | 4                | 3                | 2                | 1                | 0                |  |
| Field                          | R2D <sub>7</sub> | R2D <sub>6</sub>                   | R2D <sub>5</sub> | R2D <sub>4</sub> | R2D <sub>3</sub> | R2D <sub>2</sub> | R2D <sub>1</sub> | R2D <sub>0</sub> |  |

Data Type: 8 Bit number.

USAGE: This register set the Rest 2 to Rest 3 downshift time. Default value is 10mins. Use the formula below for calculation.

Rest2 Downshift time =  $R2D[7:0] \times 32 \times Rest2$ \_Rate.

Default = 188 x 32 x 100 = 601600ms = 10mins

All the above values are calculated base on 100Hz Hibernate clock, which expected to have 40% tolerance.

| Rest3_Rate<br>Access: R/W |                  |                  | Address: 0x19<br>Reset Value: 0x31 |                  |                  |                  |                  |                  |  |  |
|---------------------------|------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|------------------|--|--|
| Bit                       | 7                | 6                | 5                                  | 4                | 3                | 2                | 1                | 0                |  |  |
| Field                     | R3R <sub>7</sub> | R3R <sub>6</sub> | R3R <sub>5</sub>                   | R3R <sub>4</sub> | R3R <sub>3</sub> | R3R <sub>2</sub> | R3R <sub>1</sub> | R3R <sub>0</sub> |  |  |

Data Type: 8 Bit number.

USAGE: This register set the Rest 3 frame rate. Default value is 500ms. Use the formula below for calculation.

Rest3 frame rate =  $(R3R[7:0] + 1) \times 10ms$ .

Default =  $(49 + 1) \times 10 = 500 \text{ms}$ 

All the above values are calculated base on 100Hz Hibernate clock, which expected to have 40% tolerance.

| Frame_Period_Max_Bound_Lower Access: R/W |                  |                  | Address: 0x1A<br>Reset Value: 0xc0 |                  |                  |                  |                  |                  |
|------------------------------------------|------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|------------------|
| Bit                                      | 7                | 6                | 5                                  | 4                | 3                | 2                | 1                | 0                |
| Field                                    | FBM <sub>7</sub> | FBM <sub>6</sub> | FBM <sub>5</sub>                   | FBM <sub>4</sub> | FBM <sub>3</sub> | FBM <sub>2</sub> | FBM <sub>1</sub> | FBM <sub>0</sub> |

| Frame_Period_Max_Bound_Upper<br>Access: R/W |                   | Address: 0x1B<br>Reset Value: 0x5d |                   |                   |                   |                   |                  |                  |
|---------------------------------------------|-------------------|------------------------------------|-------------------|-------------------|-------------------|-------------------|------------------|------------------|
| Bit                                         | 7                 | 6                                  | 5                 | 4                 | 3                 | 2                 | 1                | 0                |
| Field                                       | FBM <sub>15</sub> | FBM <sub>14</sub>                  | FBM <sub>13</sub> | FBM <sub>12</sub> | FBM <sub>11</sub> | FBM <sub>10</sub> | FBM <sub>9</sub> | FBM <sub>8</sub> |

Data Type: 16-bit unsigned integer.

USAGE: This value sets the maximum frame period (the MINIMUM frame rate) which may be selected by the automatic frame rate control, or sets the actual frame period when operating in manual mode. To read from the registers, read Upper first followed by Lower. To write to the registers, write Lower first, followed by Upper. Units are clock cycles of the internal oscillator (nominally 47MHz). The formula is:

Frame Rate (Frames/second, fps) = Clock Frequency / Register Value

To set the frame rate manually, disable automatic frame rate mode via the Configuration\_II register and write the desired count value to these registers. Writing to the Frame\_Period\_Max\_Bound\_Upper and Lower registers also activates any new values in the following registers:

- Frame\_Period\_Max\_Bound\_Upper and Lower
- Frame\_Period\_Min\_Bound\_Upper and Lower
- Shutter\_Max\_Bound\_Upper and Lower

Any data written to these registers will be saved but will not take effect until the write to the Frame\_Period\_Max\_Bound\_Upper and Lower is complete. After writing to this register, two complete frame times are required to implement the new settings. Writing to any of the above registers before the implementation is complete may put the chip into an undefined state requiring a reset.

The three bound registers must also follow this rule when set to non-default values. There is no protection against illegal register settings, which can impact the navigation.

 $Frame\_Period\_Max\_Bound \geq Frame\_Period\_Min\_Bound + Shutter\_Max\_Bound.$ 

The following table lists some Frame Period example values with a 47MHz clock.

|            | Frame Period |      | Frame_Perio | d Register Value |
|------------|--------------|------|-------------|------------------|
| Frame Rate | Decimal      | Hex  | Upper       | Lower            |
| 1,880      | 25,000       | 61a8 | 61          | a8               |
| 1,958      | 24,000       | 5dc0 | 5d          | c0               |
| 7,200      | 6,528        | 1980 | 19          | 80               |
| 11,750     | 4,000        | 0fa0 | Of          | a0               |
|            |              |      |             |                  |

| Frame_Period_Min_Bound_Lower<br>Access: R/W |                      |                  | Address: 0x1C<br>Reset Value: 0xa0 |                  |                  |                  |                  |                  |  |  |
|---------------------------------------------|----------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|------------------|--|--|
| Bit                                         | 7                    | 6                | 5                                  | 4                | 3                | 2                | 1                | 0                |  |  |
| Field                                       | FBm <sub>7</sub>     | FBm <sub>6</sub> | FBm <sub>5</sub>                   | FBm <sub>4</sub> | FBm <sub>3</sub> | FBm <sub>2</sub> | FBm <sub>1</sub> | FBm <sub>0</sub> |  |  |
| Frame_Peri                                  | iod_Min_Bound_<br>/W | Upper            | Address: (<br>Reset Valu           |                  |                  |                  |                  |                  |  |  |
| Bit                                         | 7                    | 6                | 5                                  | 4                | 3                | 2                | 1                | 0                |  |  |

FBm<sub>15</sub> Data Type: 16-bit unsigned integer.

Field

 $FBm_{14}$ 

USAGE: This value sets the minimum frame period (the MAXIMUM frame rate) which may be selected by the automatic frame rate control. Units are clock cycles of the internal oscillator (nominally 47MHz). The minimum allowed write value is 0fa0, the maximum is 61a8. The Frame Rate formula is

FBm<sub>12</sub>

Frame Rate (Frames/second, fps) = Clock Rate / Register Value

FBm<sub>13</sub>

To read from the registers, read Upper first followed by Lower. To write to the registers, write Lower first, followed by Upper, then write anything to the Frame\_Period\_Max\_Bound Lower and Upper registers to activate the new setting. A good practice is to read the content of the Frame\_Period\_Max\_Bound registers and write it back.

FBm<sub>11</sub>

FBm<sub>10</sub>

FB<sub>m<sub>9</sub></sub>

FB<sub>m8</sub>

Reading this register will return the most recent value that was written to it. However, the value will take effect only after a write to the Frame Period Max Bound Upper and Lower registers. After writing to Frame Period Max\_Bound\_Upper, wait at least two frame times before writing to Frame\_Period\_Min\_Bound\_Upper or Lower again. Refer to Frame\_Period\_Max\_Bound register USAGE for details.

In addition, the three bound registers must also follow this rule when set to non-default values:

Frame\_Period\_Max\_Bound ≥ Frame\_Period\_Min\_Bound + Shutter\_Max\_Bound.

| Shutter_Max_Bound_Lower<br>Access: R/W |                 |                 | Address: 0x1E<br>Reset Value: 0x20 |                 |                 |                 |                 |                 |  |
|----------------------------------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|--|
| Bit                                    | 7               | 6               | 5                                  | 4               | 3               | 2               | 1               | 0               |  |
| Field                                  | SB <sub>7</sub> | SB <sub>6</sub> | SB <sub>5</sub>                    | SB <sub>4</sub> | SB <sub>3</sub> | SB <sub>2</sub> | SB <sub>1</sub> | SB <sub>0</sub> |  |

| Shutter_Max_Bound_Upper<br>Access: R/W |                  | Address: 0x1F<br>Reset Value: 0x4e |                  |                  |                  |                  |                 |                 |  |
|----------------------------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|-----------------|-----------------|--|
| Bit                                    | 7                | 6                                  | 5                | 4                | 3                | 2                | 1               | 0               |  |
| Field                                  | SB <sub>15</sub> | SB <sub>14</sub>                   | SB <sub>13</sub> | SB <sub>12</sub> | SB <sub>11</sub> | SB <sub>10</sub> | SB <sub>9</sub> | SB <sub>8</sub> |  |

Data Type: 16-bit unsigned integer.

USAGE: This value sets the maximum allowable shutter value when operating in automatic mode. Units are clock cycles of the internal oscillator (nominally 47MHz). Since the automatic frame rate function is based on shutter value, the value in these registers can limit the range of the frame rate control.

To read from the registers, read Upper first followed by Lower. To write to the registers, write Lower first, followed by Upper, then execute a write to the Frame\_Period\_Max\_Bound\_Upper and Lower registers to activate the new setting. A good practice is to read the content of the Frame\_Period\_Max\_Bound registers and write it back. To set the shutter manually, disable the AGC via the Configuration\_I register and write the desired value to these registers.

Reading this register will return the most recent value that was written to it. However, the value will take effect only after a write to the Frame\_Period\_Max\_Bound\_Upper and Lower registers. After writing to Frame\_Period\_Max\_Bound\_Upper, wait at least two frame times before writing to Shutter\_Max\_Bound\_Upper or Lower again.

In addition, the three bound registers must also follow this rule when set to non-default values:

Frame\_Period\_Max\_Bound ≥ Frame\_Period\_Min\_Bound + Shutter\_Max\_Bound.

| LASER_CTRLO<br>Access: R/W |          |          | Address: 0x<br>Reset Value |          |                 |                 |                 |                    |
|----------------------------|----------|----------|----------------------------|----------|-----------------|-----------------|-----------------|--------------------|
| Bit                        | 7        | 6        | 5                          | 4        | 3               | 2               | 1               | 0                  |
| Field                      | Reserved | Reserved | Reserved                   | Reserved | CW <sub>2</sub> | CW <sub>1</sub> | CW <sub>0</sub> | Force_<br>Disabled |

Data Type: Bit field

USAGE: This register is used to control the laser drive mode.

| Field Name     | Description                                                                                                                                                                                                                                                                     |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CW[2:0]        | Laser drive mode - Write 010b to bits [3,2,1] to set the laser to continuous ON (CW) mode Write 000b to exit laser continuous ON mode, all other values are not recommended. Reading the Motion register (0x02) will reset the value to 000b and exit laser continuous ON mode. |
| Force_Disabled | LASER force disabled  0 = LASER_NEN normal  1 = LASER_NEN force disabled                                                                                                                                                                                                        |

| <b>Observation</b> Access: R/W |                 |                 | Address:<br>Reset Val |                 |                 |                 |                 |                 |
|--------------------------------|-----------------|-----------------|-----------------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| Bit                            | 7               | 6               | 5                     | 4               | 3               | 2               | 1               | 0               |
| Field                          | OB <sub>7</sub> | OB <sub>6</sub> | OB <sub>5</sub>       | OB <sub>4</sub> | OB <sub>3</sub> | OB <sub>2</sub> | OB <sub>1</sub> | OB <sub>0</sub> |

Data Type: Bit field

USAGE: The user must clear the register by writing 0x00, wait for one frame, and read the register. The active processes will have set their corresponding bit. This register may be used as part of a recovery scheme to detect a problem caused by EFT/B or ESD.

| Field Name      | Description                                                     |
|-----------------|-----------------------------------------------------------------|
| OB <sub>6</sub> | 0 = chip is not running SROM code 1 = chip is running SROM code |
| OB[5:0]         | Set once per frame                                              |

|       | Data_Out_Lower<br>Access: Read Only |                 |                 | Address: 0x25<br>Reset Value: Undefined |                 |                 |                 |                 |  |
|-------|-------------------------------------|-----------------|-----------------|-----------------------------------------|-----------------|-----------------|-----------------|-----------------|--|
| Bit   | 7                                   | 6               | 5               | 4                                       | 3               | 2               | 1               | 0               |  |
| Field | DO <sub>7</sub>                     | DO <sub>6</sub> | DO <sub>5</sub> | DO <sub>4</sub>                         | DO <sub>3</sub> | DO <sub>2</sub> | DO <sub>1</sub> | DO <sub>0</sub> |  |

| Data_Out_l<br>Access: Re |                  |                  |                  | Address: 0x26<br>Reset Value: Undefined |                  |                  |                 |                 |  |
|--------------------------|------------------|------------------|------------------|-----------------------------------------|------------------|------------------|-----------------|-----------------|--|
| Bit                      | 7                | 6                | 5                | 4                                       | 3                | 2                | 1               | 0               |  |
| Field                    | DO <sub>15</sub> | DO <sub>14</sub> | DO <sub>13</sub> | DO <sub>12</sub>                        | DO <sub>11</sub> | DO <sub>10</sub> | DO <sub>9</sub> | DO <sub>8</sub> |  |

Data Type: 16-bit word.

USAGE: Data in these registers come from the SROM CRC test. The data can be read out in either order. The SROM CRC test is initiated by writing 0x15 to SROM\_Enable register.

| CRC Result    | Data_Out_Upper | Data_Out_Lower |
|---------------|----------------|----------------|
| SROM CRC test | BE             | EF             |

| SROM_ID Access: Read Only |                 | Address:<br>Reset Va |                 |                 |                 |                 |                 |                 |  |
|---------------------------|-----------------|----------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|--|
| Bit                       | 7               | 6                    | 5               | 4               | 3               | 2               | 1               | 0               |  |
| Field                     | SR <sub>7</sub> | SR <sub>6</sub>      | SR <sub>5</sub> | SR <sub>4</sub> | SR <sub>3</sub> | SR <sub>2</sub> | SR <sub>1</sub> | SR <sub>0</sub> |  |

Data Type: 8-bit unsigned integer.

USAGE: Contains the revision of the downloaded Shadow ROM (SROM) firmware. If the firmware has been successfully downloaded and the chip is operating out of SROM, this register will contain the SROM firmware revision; otherwise it will contain 0x00.

|       | Lift_Detection_Thr<br>Access: R/W |         | Address: 0:<br>Reset Value |                     |                     |                     |                     |                     |
|-------|-----------------------------------|---------|----------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|
| Bit   | 7                                 | 6       | 5                          | 4                   | 3                   | 2                   | 1                   | 0                   |
| Field | Reserve                           | Reserve | Reserve                    | LD_Thr <sub>4</sub> | LD_Thr <sub>3</sub> | LD_Thr <sub>2</sub> | LD_Thr <sub>1</sub> | LD_Thr <sub>0</sub> |

Data Type: 8-bit unsigned integer.

USAGE: To configure the lift detection from the nominal Z-height of 2.4mm of navigation system when ADNS-9500 sensor is coupled with ADNS-6190-002 lens. Higher value will result in higher lift detection. Different surfaces will have different lift detection values with same setting due to different surface characteristic.

| Configuration_<br>Access: R/W | V                 |                   | Address: 0x2F<br>Reset Value: 0x12 |                   |                   |                   |                   |                   |  |
|-------------------------------|-------------------|-------------------|------------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|--|
| Bit                           | 7                 | 6                 | 5                                  | 4                 | 3                 | 2                 | 1                 | 0                 |  |
| Field                         | ResY <sub>7</sub> | ResY <sub>6</sub> | ResY <sub>5</sub>                  | ResY <sub>4</sub> | ResY <sub>3</sub> | ResY <sub>2</sub> | ResY <sub>1</sub> | ResY <sub>0</sub> |  |

Data Type: Bit field.

USAGE: This register allows the user to change the Y-axis resolution when the sensor is configured to have indepedent X-axis and Y-axis resolution reporting mode via Rpt\_Mod bit = 1 in Configuration\_II register. The setting in this register will be inactive if Rpt\_Mod bit = 0. The approximate resolution value for each register setting can be calculated using the following formula. Each bit change is~90cpi. The minimum write value is 0x01 and maximum is 0x37.

Resolution value (counts per inch, cpi) = RES [7:0]  $\times$  90

| Configuration_<br>Access: R/W | Configuration_IV Access: R/W |          |          | Address: 0x39<br>Reset Value: 0x00 |          |          |           |          |
|-------------------------------|------------------------------|----------|----------|------------------------------------|----------|----------|-----------|----------|
| Bit                           | 7                            | 6        | 5        | 4                                  | 3        | 2        | 1         | 0        |
| Field                         | Reserved                     | Reserved | Reserved | Reserved                           | Reserved | Reserved | SROM_Size | Reserved |

Data Type: Bit field.

USAGE: The correct SROM file size must be selected before loading the SROM to sensor. The current SROM is 3K Bytes size.

| Field Name | Description             |  |
|------------|-------------------------|--|
| SROM_Size  | = 0: 1.5K SROM download |  |
|            | = 1: 3K SROM download   |  |

| Power_Up_Reset Access: Write Only |                  |                  |                  | Address: 0x3A<br>Reset Value: 0xNA |                  |                  |                  |                  |  |
|-----------------------------------|------------------|------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|--|
| Bit                               | 7                | 6                | 5                | 4                                  | 3                | 2                | 1                | 0                |  |
| Field                             | PUR <sub>7</sub> | PUR <sub>6</sub> | PUR <sub>5</sub> | PUR <sub>4</sub>                   | PUR <sub>3</sub> | PUR <sub>2</sub> | PUR <sub>1</sub> | PUR <sub>0</sub> |  |

Data Type: 8-Bit integer.

USAGE: Write 0x5a to this register to reset the chip. All settings will revert to default values. Reset is required after recovering from shutdown mode and restore normal operation after Frame Capture.

| Shutdown<br>Access: Write Only |                 |                 | Address: 0x3B<br>Reset Value: Undefined |                 |                 |                 |                 |                 |  |
|--------------------------------|-----------------|-----------------|-----------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|--|
| Bit                            | 7               | 6               | 5                                       | 4               | 3               | 2               | 1               | 0               |  |
| Field                          | OB <sub>7</sub> | OB <sub>6</sub> | OB <sub>5</sub>                         | OB <sub>4</sub> | OB <sub>3</sub> | OB <sub>2</sub> | OB <sub>1</sub> | OB <sub>0</sub> |  |

Data Type: 8-Bit integer.

USAGE: Write 0xb6 to set the chip to shutdown mode, use POWER\_UP\_RESET register to power up the chip. Refer to Shutdown section for more details.

| Inverse_Product_ID Access: Read Only |                  |                  | Address: 0x3F<br>Reset Value: 0xcc |                  |                  |                  |                  |                  |  |
|--------------------------------------|------------------|------------------|------------------------------------|------------------|------------------|------------------|------------------|------------------|--|
| Bit                                  | 7                | 6                | 5                                  | 4                | 3                | 2                | 1                | 0                |  |
| Field                                | PID <sub>7</sub> | PID <sub>6</sub> | PID <sub>5</sub>                   | PID <sub>4</sub> | PID <sub>3</sub> | PID <sub>2</sub> | PID <sub>1</sub> | PID <sub>0</sub> |  |

Data Type: 8-Bit unsigned integer.

USAGE: This value is the inverse of the Product\_ID, located at the inverse address. It is used to test the SPI port hardware.

|       | Motion_Burst<br>Access: Read Only |                 |                 |                 | Address: 0x50<br>Reset Value: 0x00 |                 |                 |                 |  |  |
|-------|-----------------------------------|-----------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|--|--|
| Bit   | 7                                 | 6               | 5               | 4               | 3                                  | 2               | 1               | 0               |  |  |
| Field | MB <sub>7</sub>                   | MB <sub>6</sub> | MB <sub>5</sub> | MB <sub>4</sub> | MB <sub>3</sub>                    | MB <sub>2</sub> | MB <sub>1</sub> | MB <sub>0</sub> |  |  |

Data Type: 8-Bit unsigned integer.

USAGE: The Motion\_Burst register is used for high-speed access to the Motion, Observation, Delta\_X\_L, Delta\_X\_H, Delta\_Y\_L, Delta\_Y\_H, SQUAL, Pixel\_Sum, Maximum\_Pixel, Minimum\_Pixel, Shutter\_Upper, Shutter\_Lower, Frame\_Period\_Upper and Frame\_Period\_Lower registers. See Burst Mode-Motion Read section for use details. Write any value to this register will clear all motion burst data.

| SROM_Load_Burst<br>Access: Write Only |                 |                 | Address: 0x62<br>Reset Value: Undefined |                 |                 |                 |                 |                 |  |
|---------------------------------------|-----------------|-----------------|-----------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|--|
| Bit                                   | 7               | 6               | 5                                       | 4               | 3               | 2               | 1               | 0               |  |
| Field                                 | SL <sub>7</sub> | SL <sub>6</sub> | SL <sub>5</sub>                         | SL <sub>4</sub> | SL <sub>3</sub> | SL <sub>2</sub> | SL <sub>1</sub> | SL <sub>0</sub> |  |

USAGE: The SROM\_Load\_Burst register is used for high-speed programming SROM from an external PROM or micro-controller. See SROM Download section for use details.

| Pixel_Burst<br>Access: Read Only |                 |                 |                 | Address: 0x64<br>Reset Value: 0x00 |                 |                 |                 |                 |  |  |
|----------------------------------|-----------------|-----------------|-----------------|------------------------------------|-----------------|-----------------|-----------------|-----------------|--|--|
| Bit                              | 7               | 6               | 5               | 4                                  | 3               | 2               | 1               | 0               |  |  |
| Field                            | PB <sub>7</sub> | PB <sub>6</sub> | PB <sub>5</sub> | PB <sub>4</sub>                    | PB <sub>3</sub> | PB <sub>2</sub> | PB <sub>1</sub> | PB <sub>0</sub> |  |  |

Data Type: 8-Bit unsigned integer.

USAGE: The Pixel\_Burst register is used for high-speed access to all the pixel values for one complete frame capture, without writing to the register address to obtain each pixel data. The data pointer is automatically incremented after each read so all 900 pixel values may be obtained by reading this register 900 times. See Frame Capture section for use details.

For product information and a complete list of distributors, please go to our web site: www.avagotech.com

